//给你两个字符串 haystack 和 needle ，请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标（下标从 0 开始）。
//如果 needle 不是 haystack 的一部分，则返回 -1 。 
//
// 
//
// 示例 1： 
//
// 
//输入：haystack = "sadbutsad", needle = "sad"
//输出：0
//解释："sad" 在下标 0 和 6 处匹配。
//第一个匹配项的下标是 0 ，所以返回 0 。
// 
//
// 示例 2： 
//
// 
//输入：haystack = "leetcode", needle = "leeto"
//输出：-1
//解释："leeto" 没有在 "leetcode" 中出现，所以返回 -1 。
// 
//
// 
//
// 提示： 
//
// 
// 1 <= haystack.length, needle.length <= 10⁴ 
// haystack 和 needle 仅由小写英文字符组成 
// 
//
// Related Topics 双指针 字符串 字符串匹配 👍 1629 👎 0


package leetcode.editor.cn;
public class FindTheIndexOfTheFirstOccurrenceInAString{
  public static void main(String[] args) {
       Solution solution = new FindTheIndexOfTheFirstOccurrenceInAString().new Solution();
  }
  //leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    //todo 此为朴素解法，待尝试KMP算法（看不懂，有空再看看）
    public int strStr(String haystack, String needle) {
        char[] hayStackChar = haystack.toCharArray();
        char[] needleChar = needle.toCharArray();
        for (int i=0; i<=(hayStackChar.length-needleChar.length); i++) {
            int a = i;
            int b = 0;
            while (b < needleChar.length && hayStackChar[a]==needleChar[b]){
                a++;
                b++;
            }
            if (b == needleChar.length) {
                return i;
            }
        }
        return -1;
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}